

D2



(19) BUNDESREPUBLIK

DEUTSCHLAND

DEUTSCHES  
PATENTAMT

# (17) Offenlegungsschrift (16) DE 42 05 524 A1

(5) Int. Cl.  
G 05 B 19/05  
B 65 B 57/00  
B 65 C 9/40

DE 42 05 524 A1

(21) Aktenzeichen: P 4205524.5  
 (22) Anmeldetag: 24. 2. 92  
 (30) Offenlegungstag: 27. 8. 92

(31) Unionsoberheit: (2) (3) (31)

14.11.91 EP 91 119483.5

(32) Innere Priorität: (2) (3) (31)

22.02.91 DE 41 05 6781.7

(33) Anmelder:

Siemens AG 8000 München, DE

(72) Erfinder:

Bock, Günther, Dipl.-Ing., 8450 Amberg, DE-Macht,  
 Helmut, Dipl.-Ing., 8457 Kuhmorsbruck, DE  
 Weinbacher, Christof, Dipl.-Ing. (FH), 8450 Amberg,  
 DE-Prechtl, Manfred, Dipl.-Ing. (Univ.), 8470  
 Nabburg, DE-Lengemann, Andre, Dipl.-Ing. (FH),  
 8459 Edelsfeld, DE

## (5) Speicherprogrammierbare Steuerung

(5) Es wird eine neue speicherprogrammierbare Steuerung insbesondere für Verpackungs- und Einrichtemaschinen mit mehreren Ein- (8) und Ausgängen (9) zum Anschließen von Prozessföhrelementen z. B. Sensoren oder Stellgliedern vorgeschlagen, die mindestens einen Logikbaustein (10) mit einer internen Verschaltung aufweist, über die mindestens ein Ausgang mit seinem korrespondierenden Eingang (E0) verbunden ist. Ferner wird ein Programmierverfahren für einen derartigen Logikbaustein (10) vorgestellt.



DE 42 05 524 A1

BEST AVAILABLE COPY

## Beschreibung

Die Erfundung betrifft eine speicherprogrammierbare Steuerung, insbesondere für Verpackungs- und Etikettiermaschinen, mit mehreren Ein- und Ausgängen zum Anschließen von Prozeßführungselementen, z. B. Sensoren oder Stellgliedern, sowie ein Verfahren zum Betreiben einer speicherprogrammierbaren Steuerung und ein Verfahren zum rechnergesteuerten internen elektrischen Verbinden eines umfeldprogrammierbaren Logikfeldes.

Früher wurden Maschinensteuerungen im Schütztechnik aufgebaut. Schützschaltungen arbeiten zwar parallel und sind daher schnell; sie sind jedoch störanfällig, kompliziert und nur unständlich aufzubauen bzw. anzupassen. Inzwischen sind speicherprogrammierbare Steuerungen weit verbreitet. Sie arbeiten sequentiell und sind erheblich einfacher aufgebaut und zu programmieren. Aber auch moderne speicherprogrammierbare Steuerungen sind wegen ihrer sequentiellen Arbeitsweise oftmals nicht schnell genug, z. B. für die Steuerung von Verpackungs- oder Etikettiermaschinen. Steuerungen für diese Maschinen werden in der Regel auch heute noch auf der Basis von verdrallter Logikelemente aufgebaut. Dadurch bieten diese Steuerungen zwar eine hohe Verarbeitungsgeschwindigkeit, jedoch ist das Verdrallen der Logikelemente sehr umständlich und fehlerträchtig.

Aufgabe der vorliegenden Erfundung ist es, eine speicherprogrammierbare Steuerung zur Verfügung zu stellen, mit der es möglich ist, extrem schnelle Steuerungsvorgänge zu bewältigen. Weiterhin soll ein Verfahren angegeben werden, das es ermöglicht, eine derartige speicherprogrammierbare Steuerung, die einen Logikbaustein mit einem umfeldprogrammierbaren Logikfeld enthält, schnell und einfach zu programmieren.

Die erste Aufgabe wird dadurch gelöst, daß die Steuerung mindestens einen Logikbaustein mit einer internen Verschaltung aufweist, über die mindestens ein Ausgang mit seinem korrespondierenden Eingang verbunden ist. Dadurch wird ständig das Ausgangssignal dieses Ausgangs an den Wert des korrespondierenden Eingangs angepaßt, so daß eine ansonsten nötige aufwendige Alarmreaktion bei diesem Eingang entfallen kann.

Mit Vorteil ist der Logikbaustein parallelarbeitend ausgebildet, so daß mehrere Ein- und Ausgänge miteinander verbindbar sind. Dadurch wird erreicht, daß die Ausgangssignale dieser Ausgänge keinen durch die Verarbeitungszeit verursachten Schwebungen und Schwankungen unterliegen, sondern stabil reproduzierbar sind.

Wenn die interne Verschaltung des Logikbausteins programmierbar und, insbesondere, auch reprogrammierbar ist, ist die Steuerung leicht angedeutete Anforderungen anpaßbar.

Die Programmierung des Logikbausteins ist dabei besonders einfach, wenn der Logikbaustein einen — vorgezweise statischen — Speicher zum Speichern der Bedingungen aufweist, die seine interne Verschaltung festlegen. Der Logikbaustein kann insbesondere ein umfeldprogrammierbares Logikfeld (FPGA) sein.

Wenn die Steuerung modular aufgebaut ist, ist der Logikbaustein vorteilhaft in einer Ein-/Ausgabe-Baugruppe angeordnet, weil dann der Systembus der Steuerung nicht für den Datentransfer benutzt werden muß. In diesem Fall ist es weiterhin von Vorteil, wenn der Logikbaustein direkt auf der Baugruppe programmiert werden kann, z. B. über eine Schnittstelle zum Anschluß eines Daten-Ein-/Ausgabegeräts, wobei die Schnittstel-

le direkt oder indirekt auf den Systembus oder aber auch auf den Logikbaustein selbst wirkt oder über einen zu steckbaren Anwenderspeicher, der die interne Verschaltung des Logikbausteins festlegt.

Die Steuerung arbeitet derart, daß mindestens ein Eingangssignal in einen Logikbaustein eingelesen und dort verarbeitet wird, so daß vom Logikbaustein ein mit dem Eingangssignal korrespondierendes Ausgangssignal ausgebbar ist.

Die zweite Aufgabe wird durch folgende Verfahrensschritte gelöst:

aus einem vorgegebenen funktionalen Gesamtverhalten, z. B. aufgrund eines vorgegebenen funktionalen Schaltplans, insbesondere eines Funktionsplans für eine speicherprogrammierbare Steuerung, werden interne elektrische Konfigurationen, also Verbindungen und gegebenenfalls auch Logikfunktionen, des Logikfeldes bestimmt, welche das vorgegebene funktionale Gesamtverhalten realisieren und

die so bestimmten internen elektrischen Konfigurationen, also Verbindungen und gegebenenfalls auch Logikfunktionen, werden dem Logikfeld eingeprägt,

wobei unabhängig von dem vorgegebenen funktionalen Gesamtverhalten beim Festlegen der internen elektrischen Verbindungen ein Teil der im Prinzip frei festlegbaren internen elektrischen Verbindungen festvorgegeben wird.

Wenn die Logikblöcke durch den fest vorgegebenen Teil der internen elektrischen Verbindungen in Gruppen aufgeteilt werden, die zumindest teilweise gleiche Konfigurationen aufweisen, werden regelmäßige Strukturen erzeugt, so daß das Logikfeld quasi in kleinere Einheiten, nämlich die Gruppen, zerlegt wird. Dadurch ist es nämlich möglich, das vorgegebene funktionale Gesamtverhalten in Teillfunktionen zu zerlegen, die zumindest teilweise in je einer Gruppe von Logikblöcken realisierbar sind.

Für Standard-Teillfunktionen, insbesondere komplexe Standard-Teillfunktionen, sind dabei interne elektrische Standard-Konfigurationen, also Verbindungen und gegebenenfalls auch Logikfunktionen, vorgebbar, wobei im Einzelfall die Standard-Teillfunktionen auch durch mehr als eine Gruppe von Logikblöcken realisierbar sein können.

Wenn Teillfunktionen und Standard-Teillfunktionen im Einzelfall sehr einfach sind, können gegebenenfalls mehrere von ihnen zusammengefaßt werden, sofern auch die Zusammenfassung in einer Gruppe von Logikblöcken realisierbar ist.

Die Programmierung des Logikfeldes erfolgt dann dadurch, daß

die Teillfunktionen und/oder die Standard-Teillfunktionen und/oder die Zusammenfassung den Gruppen von Logikblöcken zugeordnet werden.

unter Berücksichtigung der fest vorgegebenen internen elektrischen Verbindungen, die internen elektrischen Verbindungen ermittelt werden, die die Gruppen von Logikblöcken derart miteinander und mit externen Anschüssen verschalten, daß das vorgegebene funktionale Gesamtverhalten realisiert wird, und

die so ermittelten internen elektrischen Verbindungen dem Logikfeld eingeprägt werden, vor-

zugsweise zusammen mit den fest vorgegebenen internen elektrischen Verbindungen.

Die Programmierung des Logikfeldes ist für den Anwender besonders einfach, wenn das funktionale Gesamtverhalten in einer Programmiersprache für speicherprogrammierbare Steuerungen vorgegeben wird, insbesondere in einer graphischen Programmiersprache.

Weitere Vorteile und Einzelheiten ergeben sich aus der nachfolgenden Beschreibung eines Ausführungsbeispiels, anhand der Zeichnungen und in Verbindung mit den weiteren Unteransprüchen. Es zeigt:

Fig. 1 mehrere Baugruppen einer modular aufgebauten speicherprogrammierbaren Steuerung;

Fig. 2 den inneren Aufbau einer Ein-/Ausgabe-Baugruppe;

Fig. 3 die Verbindungen zwischen Ein- und Ausgängen;

Fig. 4 den konstruktiven Aufbau einer Ein-/Ausgabe-Baugruppe;

Fig. 5 die innere Struktur eines umfeldprogrammierbaren Logikfeldes;

Fig. 6 den Aufbau eines Logikblocks;

Fig. 7 eine beispielhaft zu lösende Problemstellung in Form einer Ampelanlage;

Fig. 8 die zugehörige schalttechnische Realisierung der Ampelanlagensteuerung;

Fig. 9 die Vorabfestlegung der internen elektrischen Verbindungen;

Fig. 10 ein Beispiel einer internen elektrischen Standardverbindung;

Fig. 11 die Realisierung des vorgegebenen Gesamtverhaltens im umfeldprogrammierbaren Logikfeld und

Fig. 12 schematisch die Kommunikation zwischen Logikbaustein und Prozessor.

Gemäß Fig. 1 besteht eine modular aufgebauten speicherprogrammierbare Steuerung aus einer Stromversorgung 1, einer Zentraleinheit 2, den Ein-/Ausgabe-Baugruppen 3, 3, 4 sowie weiteren Peripherieeinheiten 5. Die Baugruppen 3, 3, 4 sind dabei über einen Bus 5 miteinander verbunden. Die Zentraleinheit 2 weist mindestens einen Prozessor 6 zum Abarbeiten eines Programms, sowie eine Schnittstelle 7 zum Datenaustausch mit einem Programmiergerät auf.

Wie weiterhin aus Fig. 1 ersichtlich ist, wie die Baugruppe 3 einen Logikbaustein 10 auf, der z. B. ein umfeldprogrammierbares Logikfeld (FPGA) sein kann. Der Logikbaustein 10 ist über den Prozessor 11 mit dem Bus 5 und damit auch mit der Zentraleinheit 2 verbunden. Dadurch ist es möglich, von einem Programmiergerät aus über die Zentraleinheit 2 die interne Verschaltung des Logikbausteins 10 derart zu programmieren, daß die Eingänge 8 über den Logikbaustein 10 gemäß zuvor aus dem abzuarbeitenden Programm abgeleiteten logischen Bedingungen zwischen Eingangs- und Ausgangssignalen mit den Ausgängen 9 verbunden sind. Der Anwender erstellt hierzu mit dem oben erwähnten Programmiergerät zwei Programmteile. Einen zeitunkritischen Teil und einen zeitkritischen Teil. Beide Teile werden vom Programmiergerät an den Prozessor 6 der Zentraleinheit 2 übertragen. Der zeitunkritische Teil wird in der Zentraleinheit 2 abgespeichert und, wie bei speicherprogrammierbaren Steuerungen allgemein üblich, sequentiell abgearbeitet. Der zeitkritische Teil wird vom Prozessor 6 weiter an die Logikbausteine 10, 10 übertragen und von diesen in eine logische Verschaltung umgesetzt.

Die beiden Programmteile sind völlig unabhängig voneinander. Es ist jedoch über Sonderbefehle möglich, daß der Prozessor 6 und die Logikbausteine 10, 10 Informationen austauschen.

Mit Vorteil werden dabei die logischen Bedingungen, die die Verschaltung des Logikbausteins 10 festlegen, in einem statischen Speicher 12 des Logikbausteins 10 übertragen und die Verschaltung des Logikbausteins 10 aufgrund des Inhalts des Speichers 12 bestimmt.

Die Baugruppe 31 weist ebenfalls einen Logikbaustein 10 mit einem statischen Speicher 12 auf. Der Logikbaustein 10 wird jedoch über einen Anwenderspeicher 13 programmiert. Wenn die Verschaltung des Logikbausteins 10 geändert werden soll, muß der Anwenderspeicher 13 ausgetauscht bzw. umprogrammiert werden, da die logischen Bedingungen, die die Verschaltung des Logikbausteins 10 bestimmen, im Anwenderspeicher 13 abgespeichert sind.

Fig. 2 zeigt in etwas geänderter Darstellung, den elektrischen Aufbau der Baugruppe 3. Wie aus Fig. 2 ersichtlich ist, sind die Eingänge 8 mit dem Logikbaustein 10 über EingangsfILTER 14 und die Ausgänge 9 mit dem Logikbaustein 10 über Ausgangstreiber 15 verbunden. Dadurch wird erreicht, daß der Logikbaustein 10 bei einer versehentlichen Fehlvendruckum, bzw. bei einem Kurzschluß oder ähnlichen Fehlfunktionen nicht beschädigt wird. Weiterhin ist durch die EingangsfILTER 14 ein Entprellen der Eingangssignale möglich. Auch können über die Filter 14 und die Treiber 15 Signalüberlappungen vorgenommen werden, z. B. von 20 ms auf 5 V.

Der Logikbaustein 10 ist über den Bus 16 sowie die Steuereinstellungen 17 mit dem Prozessor 11 und damit auch mit dem Prozessor 6 verbunden. Dadurch wird es möglich, die korrekte Funktion des Logikbausteins 10 auch während des Betriebs zu überwachen. Zur Überwachung des Logikbausteins 10 können die Werte korrespondierender Eingänge 8 und Ausgänge 9 gleichzeitig zur Verarbeitung im Logikbaustein 10 an den Prozessor 11 und weiter an den Prozessor 6 übermittelt werden. Gegebenenfalls können auch Zwischenzustände des Logikbausteins 10, z. B. ein Merker oder ein Zeitintervall, an den Prozessor 6 gemeldet werden. Es kommen auch neue Steuerungsparameter, z. B. neue Zeitkonstanten, an den Logikbaustein 10 übertragen werden.

Die in Fig. 2 dargestellten Steuereinstellungen 17 dienen beispielweise der Übertragung eines Resetsignals mit dem die internen Merker rücksetzbar sind, sowie der Meldung des Logikbausteins 10 an den Prozessor 6 über seinen derzeitigen Programmierzustand, also z. B. der Meldung "Programmierung Logikbaustein geändert". An dieser Stelle sei erwähnt, daß die Programmierung des Logikbausteins 10 nur dann geändert werden kann, wenn der Logikbaustein 10 inaktiv ist, d.h. wenn er nicht in die Steuerung eines Prozesses eingebettet ist. Wenn der Logikbaustein 10 aus mehreren miteinander voneinander funktionsfähigen Teilen besteht, ist es auch möglich, daß nur der Teil, dessen Programmierung geändert wird, inaktiv ist.

Gemäß Fig. 3 weist der Logikbaustein 10 ein Eingangslatch 20 und ein Ausgangslatch 21 auf, die beispielweise mit einem Takt von 1 MHz getaktet sind. An die Eingänge des Eingangslatches 20 sind die Eingänge 8 angeschlossen. An die Ausgänge des Ausgangslatches 21 sind die Ausgänge 9 angeschlossen. Zwischen den Latches 20, 21 findet die eigentliche parallele Verarbeitung der Signale statt. Hierzu wird, beispielweise im

Logikschalter 22 eine elementare logische Verknüpfung der Eingänge E0 und E1 durchgeführt, gegebenenfalls auch mit Zwischenergebnissen, wie über die Leitung 23 angedeutet ist.

Das Ergebnis des Logikschalters 22 kann weiter verarbeitet werden oder auch direkt einem der Ausgänge zugeleitet werden; im gegebenen Fall dem Ausgang A0. Die Logikschalter 22 können, wie oben erwähnt, elementare logische Verknüpfungen durchführen, z.B. VERGLEICHEN, UND, ODER, NICHT-UND, NICHT-ODER. Um weitere, kompliziertere Funktionen realisieren zu können, ist es von Vorteil, wenn der Logikbaustein 10 speichernde Elemente 24 aufweist, aus denen dann z.B. Zähler, Zeitgeber oder Flankenmerker aufgebaut werden können.

Fig. 4 zeigt einen bevorzugten konstruktiven Aufbau der Ein-/Auszabe-Baugruppe 3. Wie aus Fig. 4 ersichtlich ist, ist die Baugruppe 3 eine gekapselte Flachbaugruppe, die mit einem modular aufgebauten Baugruppenträger 25 verbunden ist. Die Baugruppe 3 weist einen Schacht 26 für das z.B. in Fig. 1 dargestellte Anwendermodul 13' und eine Schnittstelle 27 zum Anschluß eines Programmiergeräts auf. Über das Anwendermodul 13' und die Schnittstelle 27 ist es möglich, den in der Baugruppe 3 enthaltenen Logikbaustein 10 direkt nicht über den Prozessor 6 zu programmieren.

Weiterhin weist die Baugruppe 3 zwei Sub-D-Steckkontakte 28a, 28b, wobei die Kontakte 28a zum Anschluß von Sensoren und die Kontakte 28b zum Anschluß von Stellgliedern dienen.

Die Kernidee der vortreffenden Erfindung ist es, ein herkömmliches, sequentielles Anwendungsprogramm für eine speicherprogrammierbare Steuerung sowohl wie möglich auf die aus der Schalttechnik bekannten Strukturen abzubilden, d.h. die korrespondierenden Ein- und Ausgänge über Logikelemente direkt zu verdrahten. Hierzu werden die logischen Bedingungen eines in einer Programmiersprache für speicherprogrammierbare Steuerungen erzeugten Anwendungsprogramms in eine Verbindungsliste konvertiert und in einem Datenfeld abgelegt. Diese Daten werden dann in den Logikbaustein 10 geladen und führen dort zu einer entsprechenden internen Verschaltung des Logikbausteins 10. Dabei ist es, wie in Fig. 4 gezeigt, möglich, mehrere dieser Logikbausteine 10, 10' schnell und/oder parallel miteinander zu verschalten. Der Programmablauf wird dadurch auf die Zentraleinheit 2 und die Baugruppen 3, 3' verteilt.

Durch die direkte Verdrahtung korrespondierender Ein- und Ausgänge miteinander entfällt für diese das bei konventionellen speicherprogrammierbaren Steuerungen benötigte Prozeßabbild. Weiterhin wird die speicherprogrammierbare Steuerung extrem schnell, die Zykluszeit geht tendenziell gegen Null. Auch wird das Alarmreaktionsverhalten reproduzierbar, da die Alarmreaktionszeit besser eingehalten wird.

Im obenstehend beschriebenen Ausführungsbeispiel wurde der Logikbaustein in einem modular aufgebauten Automatisierungsgerät verwendet. Ebenso ist jedoch auch die Verwendung in einem allein betriebsfähigen Automatisierungsgerät möglich. In der Minimalversion dieses Automatisierungsgeräts weist das Automatisierungsgerät keinen Prozessor mehr, sondern nur noch den Logikbaustein auf, so daß das abzuarbeitende Programm vom Logikbaustein allein ausgeführt wird. Die Programmierung des Logikbausteins erfolgt in diesem Fall entweder über eine Schnittstelle zu einem Programmiergerät oder über ein Speichermodul, das vom

Anwender programmiert wurde.

Die Logikbausteine 10, 10' sind im vorliegenden Fall umfeldprogrammierbare Logikfelder (FPGAs). Fig. 5 zeigt einen Ausschnitt aus der inneren Struktur eines solchen Logikfeldes. Die innere Struktur weist eine zweidimensionale Matrix von z.B. 12x12 Logikblöcken 31 auf. Diese Matrix ist von einem Ring von Ein-/Auszabe-Blöcken umgeben. Sowohl dem Anfang als auch dem Ende jeder (waagrechten) Reihe sind je zwei Ein-/Auszabe-Blöcke zugeordnet. Gleches gilt für die (senkrechten) Spalten. Die Ein-/Auszabe-Blöcke sind der Übersichtlichkeit halber nicht dargestellt. Weiterhin sind je der Reihe von Logikblöcken 31 je zwei nicht unterbrechbare Verbindungen 32 und jeder Spalte drei Verbindungen 33, von denen zwei einmal in der Mitte der Spalte unterbrochen werden können, zugeordnet. Diese Anordnung von Logikblöcken 31 und Ein-/Auszabe-Blöcken ist durchsetzt von einem Netz mit 13x13 Schaltmatrizen 34, wobei benachbarte Schaltmatrizen 34 über je fünf Kurzverbindungen 35 miteinander verbunden sind.

Die Logikblöcke 31 weisen gemäß Fig. 6 einen Kombinatorikblock 310 auf, der aus maximal 5 Eingangsvariablen 311, zwei Ausgangsvariablen 312 ermittelt. Weiterhin weist der Logikblock 31 zwei Flipflops 313, 314 auf, deren Eingangssignal entweder aus einer der Eingangsvariablen 312, der Kombinatorikblöcke 310 oder aus einer direkt über den Eingang 315 eingegebenen Variable besteht. Die Ausgangssignale der Flipflops 313, 314 können entweder in den Kombinatorikblock 310 zurückgeführt werden oder aber als eines der Ausgangssignale 316 des Logikblocks 31 ausgegeben werden. Der Logikblock 31 ist also dahingehend programmierbar, welche logische und/oder Speicherfunktion er ausführen soll.

Die beiden Ausgangsfunktionen des Logikblocks 31 sind im Prinzip unabhängig voneinander, werden im vorliegenden Fall jedoch stets gleich gewählt, da jeder der beiden Ausgänge 316 mit je zwei der vier nächsten Nachbarn seines Logikbausteins direkt verbindbar ist. Dadurch, daß die beiden Funktionen identisch sind, wird also erreicht, daß das Ausgangssignal jedes Logikblocks 31 seinen vier nächsten Nachbarn als Eingangssignal zur Verfügung gestellt werden kann. Die Topologie wird folglich strukturierter.

Weiterhin können die Ausgänge 316 mit den sie umgebenden Kurzverbindungen 35 sowie den sie umgebenden Langverbindungen 32, 33 verbunden werden. Auch sind an den Kreuzungspunkten zwischen den Langverbindungen 32, 33 untereinander sowie zwischen den Langverbindungen 32, 33 und den Kurzverbindungen 35 noch elektrische Verbindungen programmierbar.

Die Schaltmatrizen 34 sind ebenfalls programmierbar. Sie können eine Vielzahl der theoretisch denkbaren Verschaltungsmöglichkeiten realisieren, z.B. waagrechte und/oder senkrechte Durchverbindungen, Kontaktieren von waagrechten mit senkrechten Kurzverbindungen 35 und Aufteilen von einer Verbindung auf zwei oder drei.

Die Ein-/Auszabe-Blöcke sind jeweils mit einem Anschlußpin des Chips verbunden und können wahlweise entweder ein Signal eingeben oder ausgeben, wobei dieses Signal wahlweise getaktet werden kann oder nicht.

Die Programmierung der Logikblöcke 31, der Schaltmatrizen 34 und der Ein-/Auszabe-Blöcke ist jeweils lokal in diesen Elementen gespeichert, die hierzu einen kleinen statischen Speicher (SRAM) aufweisen.

Bezüglich weiteren Einzelheiten über umfeldpro-

grammierbare Logikbausteine wird auf Herstellerhandbücher verwiesen, z.B. auf Handbücher über die XC3000 Logic Cell Array Familie von Xilinx.

Zum Programmieren derartiger Logikfelder existieren ASIC-Design Tools, mittels derer die Logikfelder in der Struktur des Logikfeldes angepaßten Stromlaufanweisungen programmierbar sind. Bei diesen Anweisungen muß der ASIC-Designer jedoch viele ASIC-spezifische Randbedingungen beachten. Solche Randbedingungen sind beispielsweise Gatterlaufzeiten, der Signalpegel von ungenutzten Gattereingängen usw. Es ist offensichtlich, daß eine derartige Programmierung hardwarenabhängig und hochkomplex ist. Sie ist nur von ausgesprochenen Experten handhabbar.

Für das Umsetzen der gewünschten Programmierung in interne Verschaltungen des Logikbausteins 10 eingesetzten Programme. Die Laufzeit dieser Programme, d.h. die Umsetzung des gewünschten Gesamtverhaltens in eine interne Verschaltung des Logikfeldes, beträgt insbesondere wegen der vielfältigen Verbindungs möglichkeiten etliche Minuten, Stunden manchmal sogar Tage.

Oberstehend erwähnte Spezialkenntnisse sind dem Anwender von speicherprogrammierbaren Steuerungen nicht zumutbar, ebensowenig die extrem langen Laufzeiten der Umsetzungsprogramme. Der SPS-Anwender erwartet Laufzeiten im Sekunden-, höchstens Minutenbereich. In folgendem wird daher anhand eines Beispiels ein Verfahren beschrieben, mittels dessen ein in einer dem SPS-Anwender vertrauter Programmiersprache vorgegebenes Gesamtverhalten schnell und einfach in eine interne Verbindung des Logikfeldes umgesetzt werden kann.

Das Beispiel ist der Aufgabensammlung Simate S3 der Siemens AG, Bestell-Nr. E 40850-C 345-X-A1 entnommen und wird anhand von Fig. 7 erläutert.

Wegen Bauarbeiten muß der Verkehr auf einer Straße über eine Fahrspur geleitet werden. Da das Verkehrsaufkommen sehr hoch ist, wird eine Bedarfsspannelampe installiert. Beim Einschalten der Anlage zeigen beide Ampeln Rot. Wird ein Initiator betätigt, so schaltet die entsprechende Ampel nach 10 Sekunden auf Grün. Die Grünphase soll mindestens 20 Sekunden andauern, bevor durch eventuelle Betätigung des anderen Initiators beide Signallampen wieder Rot zeigen. Nach 10 Sekunden wird dann die andere Fahrspur mit Grün bedient. Liegt keine Meldung eines Initiators vor, so bleibt die Ampelanlage in ihrem jeweiligen Zustand. Das Ausschalten der Anlage soll nur nach der Grünphase einer Fahrspur möglich sein. Beim Einschalten der Steuerung muß der Grundzustand (M0) ohne Bedingung gesetzt werden.

Zur Umsetzung des Problems in eine SPS-Programmiersprache wird zunächst eine Übersetzung der Symbole vorgenommen, wie in der untenstehenden Tabelle angegeben:

| Symbol | Operand | Kommentar                |
|--------|---------|--------------------------|
| S0     | E0      | Schalter Ein (Schließer) |
| I1     | E1      | Initiator 1 (Schließer)  |
| I2     | E2      | Initiator 2 (Schließer)  |
| H1     | A1      | Grün                     |
| H2     | A2      | Grün                     |
| H3     | A3      | Rot                      |
| I4     | A4      | Rot                      |
| M0     | M0      | Grundzustand M0          |
| M1     | M1      | Zustand 1                |
| M2     | M2      | Zustand 2                |
| M3     | M3      | Zustand 3                |
| M4     | M4      | Zustand 4                |
| M5     | M5      | Zustand 5                |
| M6     | M6      | Zustand 6                |
| M7     | M7      | Zustand 7                |
| T1     |         | Zeit 10 Sekunden         |
| T2     |         | Zeit 20 Sekunden         |
| KT1001 |         | Zeit für Zähler 1        |
| KT2001 |         | Zeit für Zähler 2        |

Die zugehörige Verschaltung stellt sich in der SPS-Programmiersprache FUP (= Funktionsplan) wie in Fig. 8 gezeigt dar. Diese Art der Programmierung kennt der SPS-Anwender, und sie ist ihm geläufig. Die Aufgabe besteht darin, das vorgegebene in einer SPS-Programmiersprache formulierte Gesamtverhalten schnell und einfach in eine FPGA-Struktur umzusetzen, so daß der SPS-Anwender im Ergebnis in die Lage versetzt wird, den Logikbaustein 10 selbst zu programmieren.

Erreicht wird dies dadurch, daß das Programm, das das SPS-Anwenderprogramm in die zugehörige interne Verschaltung des Logikbausteins 10 umsetzt, die theoretisch mögliche Komplexität des Logikbausteins 10 vom vorherigem nur zu einem kleinen Bruchteil ausnutzt. Dies geschieht dadurch, daß ein Teil der im Programm freiwählbaren Verbindungen, z.B. die interne Verschaltung der Schaltmatrizen 34, im Umsetzungsprogramm fest vorgegeben wird, also vom Ersteller des SPS-Anwenderprogramms nicht beeinflußbar ist. Konkret werden die Verschaltungen der Schaltmatrizen 34 oder der dreizehn senkrechten Spalten derart vorgegeben, daß zum einen die oberste, die unterste sowie die mittleren drei der Schaltmatrizen 34 einer Spalte die waagerecht verlaufenden Kurzverbindungen 35 1...1 durchverbinden und die anderen der Kurzverbindungen 35 voneinander noch nicht verbinden und zum anderen die übrigen Schaltmatrizen 34 nur die senkrechten der Kurzverbindungen 35 1...1 durchverbinden und die waagerechten Kurzverbindungen 35 blockieren.

Es ergibt sich dadurch eine Struktur, wie sie in Fig. 9 dargestellt ist. Es werden Gruppen 36 gebildet, die je fünf untereinander angeordnete Logikblöcke 31 enthalten und die vorne und hinten jeweils von fünf sich über die Länge einer "Halbspalte" erstreckenden Kurzverbindungen 37 umgeben sind. Auf diese Gruppen 36 wird die zu realisierende Schaltung von Fig. 8 auf noch zu erläuternde Art und Weise abgebildet. Die beiden waagerechten mittleren Reihen von Logikblöcken 31 werden auf ebenfalls noch zu erläuternde Art und Weise zur Erzeugung von Takt signalen genutzt.

Die so entstandenen Gruppen 36 weisen eine handliche Größe auf. Einerseits ist ihre Komplexität klein genug und daher überchaubar genug, um auf relativ einfache Art und Weise abschätzen zu können, ob ein Teil-

netzwerk der zu realisierenden Gesamtschaltung durch eine der Gruppen 36 realisierbar ist; andererseits sind die Gruppen aber auch groß genug, um die Gesamt- schaltung von Fig. 8 nicht in zu kleine Teilnetzwerke zerstückeln zu müssen. Als Kriterium zur Auswahl der Teilnetzwerke dienen die zur Verfügung stehenden Verbindungsressourcen und die zur Verfügung stehende Logikkapazität der Gruppen 36. Jedes Teilnetzwerk wird derart bemessen, daß es folgende Kriterien erfüllt:

- a) es weist maximal fünf Eingangssignale auf;
- b) es weist maximal fünf Ausgangssignale auf;
- c) es werden zur Realisierung des Teilnetzwerks maximal fünf der Logikblöcke 31 benötigt und
- d) die Verdrahtung des Teilnetzwerks innerhalb der Gruppe 36 ist möglich.

Beginnend beim Oder-Gatter 81 in Fig. 8 erkennt man sofort, daß auch das Und-Gatter 82 im selben Logikblock 31 realisierbar ist, da auch die Zusammenfassung dieser beiden Funktionen erst eine kombinatorische Funktion mit drei Eingängen und einem Ausgang ergibt. Dem RS-Flipflop 83 dagegen wird ein eigener Logikblock 31 zugewiesen, da jeder der Logikblöcke 31 aufgrund einer (willkürlichen) Computervorschrift nur entweder eine kombinatorische Funktion ausführen oder eine Speicherfunktion wahrnehmen darf. Das Teilnetzwerk 84 kann folglich in einer Gruppe 36 realisiert werden, da insgesamt nur vier Eingangssignale, ein Ausgangssignal und zwei Logikblöcke 31 benötigt werden; die Kapazität einer Gruppe 36 also nicht überschritten wird.

Aufgrund ähnlicher Überlegungen ist leicht ersichtlich, daß auch die Teilnetzwerke 85 bis 88 in je einer Gruppe realisierbar sind. Vom nächsten Netzwerk 89 muß jedoch das Teilnetzwerk 90 abgetrennt werden, da sonst die Zahl der Eingänge den maximal zulässigen Wert von fünf überschreiten würde.

Analog werden die anderen Netzwerke 91 bis 100 der Gesamtschaltung aufgeteilt, aber noch nicht bestimmten Gruppen 36 zugeordnet.

Eine gewisse Schwierigkeit bei der Aufteilung der einzelnen Netzwerke besteht die Realisierung der Zeitglieder 99 und 100, da einem Zeitglied in der "SPS-Welt" kein entsprechendes Gegenstück in der "FPGA-Welt" gegenübersteht.

Um dem SPS-Anwender dennoch die leichte Programmierung von Zeitgliedern zu ermöglichen, wird diese für speicherprogrammierbare Steuerungen (SPSs) oft benötigte Funktion dem Anwender als Funktionsmacro zur Verfügung gestellt.

Zur Compilerlaufzeit erkennt der Compiler, daß ein Funktionsmacro vorliegt und setzt diesen Makro in eine interne, innerhalb des Logikfeldes verschiebbare Standard-Verbindung um. Die interne Standard-Verbindung wurde dabei vorab vom Compilerhersteller bzw. vom ASIC Designer bestimmt. Dadurch wird der Compiler nicht in hennenswertem Umfang mit der Ermittlung der Verbindungen belastet, die den Funktionsmacro realisieren.

Fig. 10 zeigt ein Beispiel einer solchen Standard-Verbindung für einen Zeitzähler, der bis zu 210 Taktzyklen abzählen kann. Die tatsächlichzählbare Zeit ist selbstverständlich noch von der Taktung des Zählers abhängig.

Das in Fig. 10 gezeigte Beispiel benötigt drei nebeneinanderliegende Gruppen 36 von Logikblöcken 31. Die genaue Abbildung der in Fig. 10 dargestellten Logik auf

FPGA-Strukturen ist dabei für den SPS-Anwender irrelevant. Bei der Erstellung derartiger Hardmakros, die mit Standard-ASIC-Design-Tools erfolgt, muß der Compiler-Hersteller bzw. der ASIC-Designer jedoch darauf achten, daß nur lokale Verbindungen, also direkte Verbindungen und Kurzverbindungen 35 verwendet werden; nicht aber globale Langverbindungen 32, 33. Hierdurch sind diese Makros nicht nur innerhalb des Logikfeldes leicht verschiebbar, also relocierbar. Sie sind auch unabhängig von den sie umgebenden Netzwerken oder Makros platzierbar.

Da Hardmakros dem SPS-Programmierer (oder Anwender) über eine Bibliothek zur Verfügung gestellt werden, die Makros also vorab erstellt worden sind, so die interne Konfiguration eines solchen Makros auch nicht an die begrenzten Möglichkeiten der Anwenderprogrammierung gebunden, sondern es kann die volle Komplexität des beanspruchten Feldbereichs ausgenutzt werden. Die Restriktionen der Anwenderprogrammierung können entfallen.

Die Erstellung derartiger Hardmakros durch den Compiler-Hersteller bzw. den ASIC-Designer und auch der Lauf der Umsetzungsprogramme kann zwar Stunden oder sogar Tage dauern. Dies ist in diesem Fall aber möglich und tolerierbar, zum einen sind nämlich nur

in der Logikblöcke 31 statt 12/12 = 144 Logikblöcke 31 miteinander zu verschalten. Zum anderen werden die Makros, wie bereits erwähnt, vorab erstellt. Der Anwender wird folglich nicht mit der Erstellung dieser Makros belastet, sondern sie stehen ihm sofort zur Verfügung. Das Vordringen des Hardmakros zu einer bestimmten Stelle im FPGA dauert aber nur Bruchteile von Sekunden. Beim Design des Hardmakros ist lediglich zu beachten, daß die vier Ein- bzw. Ausgänge "Start", "Reset", "Clock" und "Zeitablauf" leicht zugänglich sind.

Für andere mögliche Standard-Funktionen der SPS-Welt sind selbstverständlich gegebenenfalls auch größere oder kleinere diese Hardmakros möglich.

Nach der Aufgliederung der Gesamtschaltung in Teilnetzwerke 84 bis 98 werden diese zusammengefaßt, so weit auch die Zusammenfassung die obenstehend beschriebenen Kriterien a) bis d) erfüllt. Es ergibt sich beispielsweise, daß die Teilnetzwerke 87 und 94 sowie die Teilnetzwerke 30 und 37 zusammenfaßbar sind. Dieser soeben beschriebene Schritt ist nicht unbedingt nötig, er erhöht aber den Ausstanzungsgrad des Logikfeldes.

Falls wieder Erwarten im Einzelfall zur Realisierung der gewünschten Verschaltung die Zahl von fünf Eingängen bzw. fünf Ausgängen überschritten werden soll, kann dies dadurch realisiert werden, daß – je nach Bedarf – eine oder mehrere Gruppen 36 vor der Gruppe 36 die mehr als fünf Eingangssignale benötigt freigelassen werden und diese Signale ausnahmsweise mittels der waagrechten Kurzverbindungen und/oder der direkten Verbindungen von Logikblöcken 31 der davorliegenden Gruppe 36 der Gruppe 36 zugeführt werden, die mehr als fünf Eingänge benötigt. Falls auch diese zusätzlichen Verbindungsmöglichkeiten nicht ausreichen, wird eine Fehlermeldung generiert. "gewünschte Schaltung nicht generierbar. Verbindmöglichkeit zu gering".

Die einzelnen Teilnetzwerke 84 bis 100 werden nunmehr den einzelnen Gruppen 36 zugeordnet, so wie in Fig. 11 dargestellt. An dieser Stelle sei erwähnt, daß die Zuordnung der Teilnetzwerke 84 bis 100 auf die einzelnen Gruppen 36 gemäß ihrer Reihenfolge vorgenommen wurde. Dies ist die einfachste Art und Weise, eine

Zuordnung vorzunehmen; es sind aber auch komplexere Lösungen denkbar, die bereits die Verbindungen der Teilnetzwerke 84 bis 100 untereinander berücksichtigen.

Die außenliegenden Gruppen 36 werden nicht belegt, da die außenliegenden verlängerten Kurzverbindungen 37 nicht zur Anbindung dieser Gruppen zur Verfügung stehen, sondern anderweitig benötigt werden. Diese anderweitige Verwendung wird später noch erläutert werden.

Ein Beispiel einer komplexeren Lösung bei der Zuordnung der Teilnetzwerke 84 bis 100 auf die einzelnen Gruppen 36 besteht beispielsweise darin, das Netzwerk 96 in der äußersten rechten Gruppe 36 anzugeben. Dieses Netzwerk hat nämlich als einzigen Ausgang den Prozeßausgang A4. Dieser Prozeßausgang aber könnte direkt auf einen Ein-/Ausgabe-Block gelegt werden. Es würden also wieder verlängerte Kurzverbindungen 37 noch sonstige globale Verbindungsressourcen benötigt.

Nach der Zuordnung der Teilnetzwerke 84 bis 100 zu den Gruppen 36 werden die internen elektrischen Verbindungen festgelegt. Hierbei werden zunächst soweit als möglich die direkten Verbindungen zwischen den Logikblöcken 31 ausgenutzt. Im vorliegenden Beispiel der Ampelschaltung sind dies nur wenige, zumeist läuft sich nur der Merkausgang der Teilnetzwerke 84 bis 91 in das jeweils nächste Netzwerk weiterverbinden. Selbst dies ist im vorliegenden Fall aber nicht sinnvoll, da die Ausgangssignale der einzelnen Teilnetzwerke auch anderweitig benötigt werden und daher in jedem Fall auf globalere Verbindungen zurückgegriffen werden müssen.

Als erstes werden die Ein- und Ausgangssignale vom und zum zu steuernden Prozeß verbunden, also die Eingangssignale E0 bis E2 und die Ausgangssignale A1 bis A4. Soweit möglich werden die Ein- und Ausgangssignale direkt über die waagrechten Langverbindungen 32 den äußersten der verlängerten Kurzverbindungen 37 zugeführt. Falls die waagrechten Langverbindungen 32 bereits belegt sind, z. B. weil drei Signale anzuschließen sind, aber nur zwei waagrechte Langverbindungen 32 zur Verfügung stehen, werden die Signale zunächst auf senkrechte Langverbindungen 33 oder auf senkrechte Kurzverbindungen 37 gelegt. Dann werden sie über eine oder eine Reihe von Logikblöcken 31 zugeordneten Langverbindung 32 an den Rand des Logikfeldes geführt. An den Rändern des Logikfeldes werden die Ein- und Ausgangssignale mittels der verlängerten Kurzverbindungen 37 derart weiterverbunden, daß z. B. das logische Eingangssignal E0 an den physikalischen Prozeßeingang E0 angeschlossen ist.

Durch einfaches Abzählen der verbleibenden internen Ein- bzw. Ausgänge der einzelnen Netzwerke 84 bis 100 ergibt sich sodann, daß ausnahmslos stets die fünf verlängerten Kurzverbindungen 37 zwischen den Teilnetzwerken 84 bis 100 ausreichen, um die Ein- und Ausgänge der Teilnetzwerke 84 bis 100 senkrecht miteinander zu vernetzen. Falls im Einzelfall mehr als fünf Leitungen benötigt werden würden, würde zur vollständigen Verbindung auf die senkrechten Langverbindungen 33 zurückgegriffen werden, vorzugsweise zunächst auf die unterbrechbaren der Langverbindungen 33.

Durch ebensolches einfaches Abzählen ergibt sich weiterhin, daß nunmehr nur noch dreizehn verschiedene Signale innerhalb des Logikfeldes geführt werden müssen, nämlich die acht Merksignale M0 bis M7, die zwei Timer-Signale T1 und T2 sowie 3 interne Signale vom Teilnetzwerk 90 zum Teilnetzwerk 89, vom Teilnetz-

werk 93 zum Teilnetzwerk 99 und vom Teilnetzwerk 94 zum Teilnetzwerk 100.

Nunmehr ist jedoch offensichtlich, daß diese interne Verbindung leicht möglich ist. Es werden nämlich einfach nacheinander die internen Ausgangssignale in der Reihenfolge ihres Entstehens auf die beiden äußeren der drei mittleren Kurzverbindungsleisten 43 gelegt. Hierdurch sind zehn interne Signale innerhalb des gesamten Logikfeldes abgreifbar. Sie stehen damit überall als interne Eingangssignale zur Verfügung.

Die drei noch zu verbindenden internen Ausgangssignale werden auf drei der waagrechten Langverbindungen 32 gelegt, so daß sie ebenfalls abgegriffen werden können, wo sie benötigt werden. Falls eines dieser drei Signale in der oberen Reihe der Gruppen 36 als Ausgangssignal anfällt, jedoch in der unteren Reihe von Gruppen 36 benötigt wird, wird dieses Problem wie folgt gelöst. Das jeweilige interne Ausgangssignal wird auf eine der waagrechten Langverbindungen 32 in der oberen Hälfte des Logikfeldes gelegt, diese waagrechte Langverbindung 32 mit einer senkrechten Langverbindung 33 verbunden und die senkrechte Langverbindung 33 mit einer waagrechten Langverbindung 32 verbunden, die in der unteren Hälfte des Logikfeldes angeordnet ist. Hierdurch steht dieses Signal auch in der unteren Hälfte des Logikfeldes zur Verfügung.

In analoger Weise wird selbstverständlich verfahren, wenn ein internes Signal in der unteren Hälfte des Logikfeldes erzeugt, jedoch in der oberen Hälfte als Eingangssignal benötigt wird.

Darüber hinaus lassen sich bei vorausschauender Anordnung der Netzwerke 84 bis 100 innerhalb des Logikfeldes drei der internen Signale direkt verbinden, so daß für die dann noch verbleibenden zehn internen Signale, die beiden äußeren der Kurzverbindungsleisten 43 ausreichen.

Die oben stehend erwähnten drei internen Signale fallen nämlich jeweils nur einmal als Ausgangssignal, nämlich in den Teilnetzwerken 90, 93 und 94, und werden auch nur einmal als Eingangssignale benötigt, nämlich von den Teilnetzwerken 89, 99 und 100. Wenn also die Teilnetzwerke 90 und 99, 93 und 99 sowie 94 und 100 jeweils unmittelbar untereinander abgeordnet werden können, diese Signale direkt über Nachbar-Nachbar-Verbindungen der Logikblöcke 31 untereinander verbunden werden. Auch ist eine Verbindung über die zwischen den jeweiligen Teilnetzwerkpaaren liegende verlängerte Kurzverbindung 37 möglich. In beiden Fällen werden keine waagrechten Verbindungen 32, 41, 42, 43 benötigt. Diese Verbindungen stehen damit anderweitig zur Verfügung.

Für die Taktung der Zeitzähler 99, 100 werden innerhalb des Logikfeldes Systemtakte von 1 ms, 10 ms, 100 ms und 1 sec bereitgestellt. Dies geschieht auf folgende Art und Weise: Mittels ASIC Design Tools werden hierzu vom Compiler-Hersteller vorab Teilerstufen erstellt, die einen beliebigen von außen eingekoppelten Systemtakt auf ein 1/10, 1/100 und 1/1000 seiner ursprünglichen Frequenz herunterteilen. Dieser Makro, im folgenden Teiltakmakro genannt, wird dabei derart erstellt, daß er nur die beiden mittleren, bisher ungenutzten Reihen von Logikblöcken 31 sowie die direkten Verbindungen zwischen diesen Logikblöcken benötigt. Dieser Teil der (System-) Programmierung des FPCAs steht fest und ändert sich nicht. Von außerhalb des Logikbausteins 10 wird über einen der Ein-/Ausgabe-Puffer ein Takt von 1 ms direkt in diesen Teiltakmakro eingekoppelt.

Die vier FPGA-internen Systemtakte von 1, 10, 100 und 1000 ms werden beispielsweise je einer der vier waagrechten Langverbindungen 32 zugeordnet, die den beiden mittleren Reihen von Logikblöcken 31 zugeordnet sind. Diese vier Zeitakte stehen damit im ganzen Logikfeld bereit und können dementsprechend abgegriffen werden. Welcher der Systemtakte an die Zeitzähler 99, 100 angeschlossen wird, ergibt sich für den Compiler aus der Bezeichnung der Eingangsvariablen  $KT_{x,y}$ :  $x$  bezeichnet nach allgemeiner Regelung die Zahl der zuzählenden Taktzyklen und  $y$  ist ein Code für die Zeiteinheit. 200 bedeutet also beispielsweise, daß 200 Zyklen des Taktes mit dem Code 1, d.h. 100 ms zu zählen sind. Im Ergebnis muß der Zeitzähler 100 also 200.100 ms = 20 sec.

Zum ordnungsgemäßen Ablauf des Steuerungsprogramms müssen im Regelfall die Logikbausteine 10, 10' und die Zentraleinheit 2 auch während des Betriebs Daten miteinander austauschen. Es kann beispielsweise sein, daß die Parametrierung des Logikbausteins 10 während des Betriebs geändert werden soll. Weiterhin sollte die Zentraleinheit 2 mindestens zeitweise über den aktuellen Zustand des Logikbausteins 10 (bzw. 10') informiert werden. Der Prozessor 6 und die Logikbausteine 10, 10' sind jedoch nicht miteinander synchronisiert. Es stellt sich daher das Problem der Datenkonsistenz. Das Problem wird dadurch noch vergrößert, daß der Datenverkehr zwischen Prozessor 6 und Logikbaustein 10, 10' seriell verläuft. Der serielle Datenverkehr ist nötig, da ansonsten zu viele Pins der Logikbausteine 10, 10' für den Datenverkehr mit dem Prozessor 6 benötigt würden.

Das Problem wird dadurch gelöst, daß dem Anwender weitere Funktionsmakros zur Verfügung gestellt werden. Diese Funktionsmakros realisieren Schieberegister, die der Zwischenspeicherung von Ein- oder Ausgabedaten dienen sowie Arbeitsspeicher. Dabei werden zunächst die neu einzugebenden Daten vom Prozessor 6 in die Schreibzwischenspeicher, z.B. des Logikbausteins 10 eingeschrieben. Während dieser Zeit sind die in den Zwischenspeichern abgespeicherten Werte, war im Logikbaustein 10 vorhanden, werden aber vorerst nicht verwendet, da sie vorerst noch nicht freigegeben wurden. Mittels eines eigenen Befehls werden sodann die neu in den Logikbaustein 10 eingeschriebenen Werte von den Zwischenspeichern in die Arbeitsspeicher übernommen. Gleichzeitig werden die aus dem Logikbaustein 10 auszulesenden Werte in andere, sogenannte Lesezwischenspeicher eingelesen. Sodann werden die Daten seriell aus diesen Lesezwischenspeichern in den Prozessor 6 ausgelesen.

Fig. 12 zeigt ein Beispiel eines solchen Datenzyklus. Im vorliegenden Fall werden zum Übertragen aller benötigten Signale fünf Leitungen benötigt. Dabei werden auf den Leitungen folgende Informationen übertragen:

Solange der Signalpegel der Leitung RW Null ist, können Daten in die Schreibzwischenspeicher geschrieben werden. Solange der Signalpegel der Leitung RW 1 ist, können Daten aus den Lesezwischenspeichern gelesen werden. Alle Zwischenspeicher sind derart an die Leitung RW angeschlossen, daß sie auf die ansteigende Signallanke der Leitung RW getriggert sind. Zum Triggerzeitpunkt werden zum einen die Daten aus den Schreibzwischenspeichern in die Arbeitsspeicher übernommen. Zum anderen werden Daten aus den Logikblöcken 31 in die dafür vorgesehenen Lesezwischenspeicher übernommen.

Die Signale PA1 und PA2 sind Adresssignale. Mit

der Adresssignale PA1 und PA2 können maximal je drei Schreibzwischenspeicher und Lesezwischenspeicher adressiert werden. Der theoretisch mögliche vierte Speicher (2 Signale =  $2^2 = 4$  Adressierungsmöglichkeiten) darf nicht verwendet werden. Diese Pegel werden nämlich an den Logikbaustein 10 angelegt, wenn keine Daten eingelesen bzw. ausgeleren werden. Daher darf diese Adresse, z.B. die Doppelnull, nicht verwendet werden.

CLK ist ein Takt. Wenn CLK Eins ist, liest der jeweils angesprochene Zwischenspeicher ein neues Bit ein bzw. aus.

Data ist die Datenleitung, auf der die Information selbst übertragen wird. Im vorliegenden Beispiel werden (rein zufällig) langer Einsen übertragen.

Es ergibt sich aufgrund einfacher Überlegung, daß zum Lesen bzw. Schreiben der Zwischenspeicher mindestens vier Leitungen benötigt werden, nämlich die Leitungen RW, CLK, Data sowie mindestens eine Adreßleitung. Diese vier Signale werden auf die mittlere, bisher ungenutzte der drei Kurzverbindungsleisten 43 gelegt. Dadurch stehen diese vier Signale quer über den gesamten Logikbaustein 10 zur Verfügung. Falls überhaupt keine Parameter ein- und auszulesen sind, steht auch die mittlere der drei Kurzverbindungsleisten 43 für die interne Verbindung der Gruppen 36 zur Verfügung.

Falls mehr als drei Lesezwischenspeicher bzw. Schreibzwischenspeicher zu adressieren sind, werden weitere Adresssignale PA3, PA4 etc. an den Logikbaustein 10 angelegt. Diese zusätzlichen Adresssignale werden im Regelfall auf zwei waagrechte Langverbindungen 32 gelegt, wobei die eine der Langverbindungen 32 in der oberen Hälfte des Logikfeldes und die andere in der unteren Hälfte des Logikfeldes angeordnet ist.

Es bedarf keiner Erwähnung, daß die Bildung von zusätzlichen Speichermakros Logikfeldkapazitäten beansprucht. Diese Logikfeldkapazitäten stehen selbstverständlich anderweitig nicht mehr zur Verfügung.

Die obenerwähnten Speichermakros sind, ebenso wie die Timer, vorab vom Compilervorsteller mit ASIC Design-Tools erstellt worden. Dem Compilervorsteller ist dabei im Rahmen seines allgemeinen Fachwissens bekannt, wie Register und Schieberegister aufzubauen sind. Ebenso ist in der Elektronik allgemein bekannt, wie Schieberegister mittels Adreßleitungen anzusteuern sind, so daß nur jeweils eines angesprochen wird. Derartige Speicherkonfigurationen bedürfen daher im Rahmen der vorliegenden Erfindung keiner weiteren Erläuterung.

Damit sind nun alle wesentlichen Schritte zur schnellen und einfachen Umsetzung eines SPS-Programms in eine FPGA-Struktur bekannt. Die nunmehr bekannten internen elektronischen Verbindungen und die nunmehr ebenfalls ermittelte Programmierung der einzelnen Logikblöcke 31 werden in an sich bekannter Weise dem Logikfeld eingeprägt, so daß es also das gewünschte Gesamtverhalten, hier die Ampelsteuerung, realisiert. Weiterhin erhält der Anwender eine Meldung über den Ausnutzungsgrad des Logikfeldes oder, falls die Realisierung nicht möglich ist, eine bezügliche Meldung sowie eine Information darüber, warum die Realisierung nicht möglich war, z.B. weil keine Verbindungsstellen mehr zur Verfügung standen.

Die im vorliegenden Fall als Ausführungsbeispiel gewählte Ampelsteuerung ist selbstverständlich nicht so zeitkritisch wie andere Steuerungsvorgänge. Sie wurde jedoch gewählt, da sich anhand dieses einfachen Be-

spiels die prinzipielle Vorgehensweise einfach erläutern läßt.

Im Ergebnis ergibt sich damit ein umfeldprogrammierbares Logikfeld, das zwar bei weitem nicht optimal ausgenutzt ist, dessen Programmierung aber schnell und einfach und vor allem in einer dem SPS-Anwender vertrauten Art und Weise erfolgt.

#### Patentansprüche:

1. Speicherprogrammierbare Steuerung, insbesondere für Verpackungs- und Etikettiermaschinen, mit mehreren Ein- (8) und Ausgängen (9) zum Anschließen von Prozeßführungelementen, z. B. Sensoren oder Stellgliedern, dadurch gekennzeichnet, daß die Steuerung mindestens einen Logikbaustein (10) mit einer internen Verschaltung aufweist, über die mindestens ein Ausgang (40) mit seinem entsprechenden Eingang (E0) verbunden ist.
2. Steuerung nach Anspruch 1., dadurch gekennzeichnet, daß der Logikbaustein (10) parallelarbeitend ausgebaut ist.
3. Steuerung nach Anspruch 1. oder 2., dadurch gekennzeichnet, daß die interne Verschaltung des Logikbausteins (10) programmierbar und insbesondere auch reprogrammierbar ist.
4. Steuerung nach Anspruch 1., 2. oder 3., dadurch gekennzeichnet, daß der Logikbaustein (10) einen vorzugsweise statischen - Speicher (12) zum Speichern der Bedingungen aufweist, die seine interne Verschaltung festlegen.
5. Steuerung nach Anspruch 1., 2., 3. oder 4., dadurch gekennzeichnet, daß der Logikbaustein (10) ein umfeldprogrammierbares Logikfeld (EPGA) ist.
6. Steuerung nach Anspruch 1., 2., 3. oder 5., dadurch gekennzeichnet, daß die Steuerung mindestens einen Prozessor (6) und einen mit dem Prozessor (6) verbundenen Bus (5) aufweist, wobei der Ein- (8) und der Ausgang (9) sowohl mit dem Logikbaustein (10) als auch mit dem Bus (5) — auch zugleich — verbindbar sind.
7. Steuerung nach Anspruch 6., dadurch gekennzeichnet, daß der Prozessor (6) über mindestens eine Steuerleitung (17) mit dem Logikbaustein (10) verbunden ist.
8. Steuerung nach einem der obigen Ansprüche, dadurch gekennzeichnet, daß sie mindestens einen Anwenderspeicher (13) aufweist, der die interne Verschaltung des Logikbausteins (10) festlegt.
9. Steuerung nach einem der obigen Ansprüche, dadurch gekennzeichnet, daß der Logikbaustein (10) mindestens einen Anschluß (17) für ein Taktsignal aufweist.
10. Steuerung nach einem der obigen Ansprüche, dadurch gekennzeichnet, daß der Eingang (8) über einen EingangsfILTER (14) und der Ausgang (9) über einen Ausgangstreiber (15) mit dem Logikbaustein (10) verbunden ist.
11. Steuerung nach einem der obigen Ansprüche, dadurch gekennzeichnet, daß die Steuerung modular aufgebaut ist und der Logikbaustein (10) in einer Ein-/Auszabc-Baugruppe (3) angeordnet ist.
12. Steuerung nach Anspruch 8. und 11., dadurch gekennzeichnet, daß die Ein-/Auszabc-Baugruppe (3) einen Steckplatz (26) für den Anwenderspeicher (13) aufweist.
13. Steuerung nach Anspruch 11. oder 12., dadurch gekennzeichnet, daß die Baugruppe (3) eine

Schnittstelle (27) zum Anschluß eines Daten-Ein-/Ausgabegeräts, z. B. eines Programmiergeräts, aufweist.

14. Steuerung nach Anspruch 11., 12. oder 13., dadurch gekennzeichnet, daß die Baugruppe mehrpolige Steckkontakte (28a, 28b) zum Anschließen der Prozeßführungselemente aufweist.
15. Verfahren zum Befreien einer speicherprogrammierbaren Steuerung nach einem oder mehreren der obigen Ansprüche, dadurch gekennzeichnet, daß mindestens ein Eingangssignal in einen Logikbaustein (10) eingelesen und dort verarbeitet wird, so daß vom Logikbaustein (10) ein mit dem Eingangssignal korrespondierendes Ausgangssignal ausgebbar ist.
16. Verfahren nach Anspruch 15., dadurch gekennzeichnet, daß das Einkleben, Verarbeiten und Ausgeben getaktet ist.
17. Verfahren nach Anspruch 15. oder 16., dadurch gekennzeichnet, daß das Eingangssignal gefiltert; insbesondere entspreilt wird.
18. Verfahren nach einem der Ansprüche 15. bis 17., dadurch gekennzeichnet, daß der Logikbaustein (10) mit einem Prozessor (6) über mindestens eine Leitung (17) Daten austauscht.
19. Verfahren nach einem der Ansprüche 15. bis 18., dadurch gekennzeichnet, daß zum Festlegen der Programmierung des Logikbausteins (10) zumindest der Ein- (8) und der Ausgang (9) mit einem Bus (5) verbunden werden.
20. Verfahren nach einem der Ansprüche 15. bis 19., dadurch gekennzeichnet, daß der Datenverkehr des Logikbausteins (10) mit dem Bus (5) über einen dem Logikbaustein (10) zugeordneten Prozessor (11) erfolgt.
21. Programmierverfahren zum rechnergesteuerten internen elektrischen Verbinden eines umfeldprogrammierbaren Logikfeldes, das aus einer mindestens zweidimensionalen Anordnung von Logikblöcken (31) besteht; die durch vom Anwender frei festlegbare interne elektrische Verbindungen miteinander und mit dem Umfeld verbindbar sind,  
— wobei aus einem vorgegebenen funktionalen Gesamtverhalten, z. B. aufgrund eines vorgegebenen funktionalen Schaltparts, insbesondere eines Funktionsplans für eine speicherprogrammierbare Steuerung, interne elektrische Konfigurationen, also Verbindungen und gegebenenfalls auch Logikfunktionen, des Logikfeldes bestimmt werden, welche das vorgegebene funktionale Gesamtverhalten realisieren,  
— wobei die so bestimmten internen elektrischen Konfigurationen, also Verbindungen und gegebenenfalls auch die Logikfunktionen, dem Logikfeld eingeprägt werden;  
— und wobei unabhängig vom vorgegebenen funktionalen Gesamtverhalten beim Festlegen der internen elektrischen Verbindungen ein Teil der im Prinzip frei festlegbaren internen elektrischen Verbindungen fest vorgegeben wird.
22. Verfahren nach Anspruch 21., dadurch gekennzeichnet, daß die Logikblöcke (31) durch den fest vorgegebenen Teil der internen elektrischen Verbindungen in Gruppen (36) aufgeteilt werden, die zumindest teilweise gleiche Konfigurationen aufweisen.

# DE 42 05 524 A1

17

23. Verfahren nach Anspruch 22, dadurch gekennzeichnet, daß das vorgegebene funktionale Gesamtverhalten in Teifunktionen (84-100) zerlegt wird, die zumindest teilweise in je einer Gruppe (36) von Logikblöcken (31) realisierbar sind.

24. Verfahren nach Anspruch 22 oder 23, dadurch gekennzeichnet, daß für Standard-Teifunktionen (99, 100), insbesondere komplexe Standard-Teifunktionen (99, 100), interne elektrische Standard-Konfigurationen, also Verbindungen und gegebenenfalls auch Logikfunktionen, vorgebbar sind.

25. Verfahren nach Anspruch 24, dadurch gekennzeichnet, daß die Standard-Teifunktionen (99, 100) durch mehr als eine Gruppe (36) von Logikblöcken (31) realisierbar sind.

26. Verfahren nach Anspruch 23 oder 24, dadurch gekennzeichnet, daß Teifunktionen (84-98) und Standard-Teifunktionen (99, 100), die in einer Gruppe (36) von Logikblöcken (31) realisierbar sind, zusammengefaßt werden, sofern auch die Zusammenfassung in einer Gruppe (36) von Logikblöcken (31) realisierbar ist.

27. Verfahren nach einem der Ansprüche 21 bis 26, dadurch gekennzeichnet, daß

- die Teifunktionen (84-98) und/oder die Standard-Teifunktionen (99, 100) und/oder die Zusammenfassung der Gruppen (36) von Logikblöcken (31) zugeordnet werden;

- unter Berücksichtigung der fest vorgegebenen internen elektrischen Verbindungen die internen elektrischen Verbindungen ermittelt werden, die die Gruppen (36) von Logikblöcken (31) derart miteinander verschalten, daß das vorgegebene funktionale Gesamtverhalten realisiert wird; und

- die so ermittelten internen elektrischen Verbindungen dem Logikfeld eingeprägt werden, vorzugsweise zusammen mit den fest vorgegebenen internen elektrischen Verbindungen;

28. Verfahren nach Anspruch 27, dadurch gekennzeichnet, daß bei einem Logikfeld mit lang/rechtwinkigen Langverbindungen (32, 33) und kurz/rechtwinkigen Kurzverbindungen (35) die elektrischen Verbindungen zu Prozeßeingängen und Prozeßausgängen, zumindest teilweise über die Langverbindungen (32/33) erfolgen.

29. Verfahren nach Anspruch 27 oder 28, dadurch gekennzeichnet, daß bei einem Logikfeld mit lang/rechtwinkigen Langverbindungen (32, 33) und kurz/rechtwinkigen Kurzverbindungen (35) die internen elektrischen Verbindungen soweit als möglich über die Kurzverbindungen (35) erfolgen und nur die über die Kurzverbindungen (35) nicht realisierbaren internen elektrischen Verbindungen über die Langverbindungen (32, 33) erfolgen.

30. Verfahren nach Anspruch 29, dadurch gekennzeichnet, daß die Langverbindungen (32, 33) teilweise unterbrechbar sind; und daß die internen elektrischen Verbindungen erst dann über die nicht unterbrechbaren Langverbindungen (32, 33) erfolgen, wenn die internen elektrischen Verbindungen über die unterbrechbaren Langverbindungen (32, 33) nicht realisierbar sind.

31. Verfahren nach einem der Ansprüche 21 bis 30, dadurch gekennzeichnet, daß das funktionale Gesamtverhalten in einer Programmiersprache für speicherprogrammierbare Steuerungen vorge-

18

ben wird.

32. Verfahren nach einem der Ansprüche 21 bis 31, dadurch gekennzeichnet, daß das funktionale Gesamtverhalten in einer graphischen Programmiersprache vorgegeben wird.

Hierzu 14 Seite(n) Zeichnungen



FIG. 1

ZEICHNUNGEN SEITE 2

નુરગણ્ય

५०

## Offenlegungstage

DE 4205524 A1

G 05.B.19/05

27 August 1992



FIG 2



**FIG 3.**



FIG. 6

ZEICHNUNGEN SEITE 4

Nummer:  
Int.Cl.:  
Offenlegungstag:

DE 42 05 624 A1  
G 05 G 19/06  
27. August 1992



FIG. 5



FIG. 6

ZEICHNUNGEN SEITE B

Nummer:

DE 42 06 524 A1

Int.Cl.5

G 06 B 19/06

Offenlegungstag:

27. August 1992



FIG 7





FIG 8e



FIG 8f



FIG 8g



FIG 8h

**This Page is Inserted by IFW Indexing and Scanning  
Operations and is not part of the Official Record**

**BEST AVAILABLE IMAGES**

Defective images within this document are accurate representations of the original documents submitted by the applicant.

Defects in the images include but are not limited to the items checked:

- BLACK BORDERS**
- IMAGE CUT OFF AT TOP, BOTTOM OR SIDES**
- FADED TEXT OR DRAWING**
- BLURRED OR ILLEGIBLE TEXT OR DRAWING**
- SKEWED/SLANTED IMAGES**
- COLOR OR BLACK AND WHITE PHOTOGRAPHS**
- GRAY SCALE DOCUMENTS**
- LINES OR MARKS ON ORIGINAL DOCUMENT**
- REFERENCE(S) OR EXHIBIT(S) SUBMITTED ARE POOR QUALITY**
- OTHER:** \_\_\_\_\_

**IMAGES ARE BEST AVAILABLE COPY.**

**As rescanning these documents will not correct the image problems checked, please do not report these problems to the IFW Image Problem Mailbox.**

**THIS PAGE BLANK (USPTO)**